<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Testsuite</title>
<link rel="stylesheet" href="../../../doc/src/boostbook.css" type="text/css">
<meta name="generator" content="DocBook XSL Stylesheets V1.79.1">
<link rel="home" href="../index.html" title="The Boost C++ Libraries BoostBook Documentation Subset">
<link rel="up" href="../function.html" title="Chapter 16. Boost.Function">
<link rel="prev" href="misc.html" title="Miscellaneous Notes">
<link rel="next" href="../heap.html" title="Chapter 17. Boost.Heap">
</head>
<body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF">
<table cellpadding="2" width="100%"><tr>
<td valign="top"><img alt="Boost C++ Libraries" width="277" height="86" src="../../../boost.png"></td>
<td align="center"><a href="../../../index.html">Home</a></td>
<td align="center"><a href="../../../libs/libraries.htm">Libraries</a></td>
<td align="center"><a href="http://www.boost.org/users/people.html">People</a></td>
<td align="center"><a href="http://www.boost.org/users/faq.html">FAQ</a></td>
<td align="center"><a href="../../../more/index.htm">More</a></td>
</tr></table>
<hr>
<div class="spirit-nav">
<a accesskey="p" href="misc.html"><img src="../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../function.html"><img src="../../../doc/src/images/up.png" alt="Up"></a><a accesskey="h" href="../index.html"><img src="../../../doc/src/images/home.png" alt="Home"></a><a accesskey="n" href="../heap.html"><img src="../../../doc/src/images/next.png" alt="Next"></a>
</div>
<div class="section">
<div class="titlepage"><div><div><h2 class="title" style="clear: both">
<a name="function.testsuite"></a>Testsuite</h2></div></div></div>
<div class="toc"><dl class="toc">
<dt><span class="section"><a href="testsuite.html#function.testsuite.acceptance">Acceptance tests</a></span></dt>
<dt><span class="section"><a href="testsuite.html#function.testsuite.negative">Negative tests</a></span></dt>
</dl></div>
<div class="section">
<div class="titlepage"><div><div><h3 class="title">
<a name="function.testsuite.acceptance"></a>Acceptance tests</h3></div></div></div>
<div class="informaltable"><table class="table">
<colgroup>
<col>
<col width="1in">
<col>
</colgroup>
<thead><tr>
<th>Test</th>
<th>Type</th>
<th>Description</th>
<th>If failing...</th>
</tr></thead>
<tbody>
<tr>
<td><p><a href="../../../libs/function/test/function_test.cpp" target="_top">function_test.cpp</a></p></td>
<td><p>run</p></td>
<td><p>Test the capabilities of the <code class="computeroutput"><a class="link" href="../boost/function.html" title="Class template function">boost::function</a></code> class template.</p></td>
<td><p>The <code class="computeroutput"><a class="link" href="../boost/function.html" title="Class template function">boost::function</a></code> class template may not be usable on your compiler. However, the library may still be usable via the <code class="computeroutput"><a class="link" href="../boost/functionN.html" title="Class template functionN">boost::functionN</a></code> class templates.</p></td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/function_n_test.cpp" target="_top">function_n_test.cpp</a></p></td>
<td><p>run</p></td>
<td><p>Test the capabilities of the <code class="computeroutput"><a class="link" href="../boost/functionN.html" title="Class template functionN">boost::functionN</a></code> class templates.</p></td>
<td> </td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/allocator_test.cpp" target="_top">allocator_test.cpp</a></p></td>
<td><p>run</p></td>
<td><p>Test the use of custom allocators.</p></td>
<td><p>Allocators are ignored by the implementation.</p></td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/stateless_test.cpp" target="_top">stateless_test.cpp</a></p></td>
<td><p>run</p></td>
<td><p>Test the optimization of stateless function objects in the Boost.Function library.</p></td>
<td><p>The exception-safety and performance guarantees given for stateless function objects may not be met by the implementation.</p></td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/lambda_test.cpp" target="_top">lambda_test.cpp</a></p></td>
<td><p>run</p></td>
<td><p>Test the interaction between Boost.Function and Boost.Lambda.</p></td>
<td><p>Either Boost.Lambda does not work on the platform, or Boost.Function cannot safely be applied without the use of <code class="computeroutput">boost::unlambda</code>.</p></td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/contains_test.cpp" target="_top">contains_test.cpp</a></p></td>
<td><p>run</p></td>
<td><p>Test the operation of the
    <code class="computeroutput">target</code> member function and the
    equality operators.</p></td>
<td> </td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/function_30.cpp" target="_top">function_30.cpp</a></p></td>
<td><p>compile</p></td>
<td><p>Test the generation of a Boost.Function function object adaptor accepting 30 arguments.</p></td>
<td><p>The Boost.Function library may work for function object adaptors of up to 10 parameters, but will be unable to generate adaptors for an arbitrary number of parameters. Failure often indicates an error in the compiler's preprocessor.</p></td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/function_arith_cxx98.cpp" target="_top">function_arith_cxx98.cpp</a></p></td>
<td><p>run</p></td>
<td><p>Test the first tutorial example.</p></td>
<td> </td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/function_arith_portable.cpp" target="_top">function_arith_portable.cpp</a></p></td>
<td><p>run</p></td>
<td><p>Test the first tutorial example.</p></td>
<td> </td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/sum_avg_cxx98.cpp" target="_top">sum_avg_cxx98.cpp</a></p></td>
<td><p>run</p></td>
<td><p>Test the second tutorial example.</p></td>
<td> </td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/sum_avg_portable.cpp" target="_top">sum_avg_portable.cpp</a></p></td>
<td><p>run</p></td>
<td><p>Test the second tutorial example.</p></td>
<td> </td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/mem_fun_cxx98.cpp" target="_top">mem_fun_cxx98.cpp</a></p></td>
<td><p>run</p></td>
<td><p>Test member function example from tutorial.</p></td>
<td> </td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/mem_fun_portable.cpp" target="_top">mem_fun_portable.cpp</a></p></td>
<td><p>run</p></td>
<td><p>Test member function example from tutorial.</p></td>
<td> </td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/std_bind_cxx98.cpp" target="_top">std_bind_cxx98.cpp</a></p></td>
<td><p>run</p></td>
<td><p>Test standard binders example from tutorial.</p></td>
<td> </td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/std_bind_portable.cpp" target="_top">std_bind_portable.cpp</a></p></td>
<td><p>run</p></td>
<td><p>Test standard binders example from tutorial.</p></td>
<td> </td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/function_ref_cxx98.cpp" target="_top">function_ref_cxx98.cpp</a></p></td>
<td><p>run</p></td>
<td><p>Test <code class="computeroutput">boost::ref</code> example from tutorial.</p></td>
<td> </td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/function_ref_portable.cpp" target="_top">function_ref_portable.cpp</a></p></td>
<td><p>run</p></td>
<td><p>Test <code class="computeroutput">boost::ref</code> example from tutorial.</p></td>
<td> </td>
</tr>
</tbody>
</table></div>
</div>
<div class="section">
<div class="titlepage"><div><div><h3 class="title">
<a name="function.testsuite.negative"></a>Negative tests</h3></div></div></div>
<div class="informaltable"><table class="table">
<colgroup>
<col>
<col width="1in">
<col>
</colgroup>
<thead><tr>
<th>Test</th>
<th>Type</th>
<th>Description</th>
<th>If failing...</th>
</tr></thead>
<tbody>
<tr>
<td><p><a href="../../../libs/function/test/function_test_fail1.cpp" target="_top">function_test_fail1.cpp</a></p></td>
<td><p>compile-fail</p></td>
<td><p>Test the (incorrect!) use of comparisons between Boost.Function function objects.</p></td>
<td><p>Intuitive (but incorrect!) code may compile and will give meaningless results.</p></td>
</tr>
<tr>
<td><p><a href="../../../libs/function/test/function_test_fail2.cpp" target="_top">function_test_fail2.cpp</a></p></td>
<td><p>compile-fail</p></td>
<td><p>Test the use of an incompatible function object with Boost.Function</p></td>
<td><p>Incorrect code may compile (with potentially unexpected results).</p></td>
</tr>
</tbody>
</table></div>
</div>
</div>
<table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr>
<td align="left"></td>
<td align="right"><div class="copyright-footer">Copyright © 2001-2004 Douglas Gregor<p>Use, modification and distribution is subject to the Boost
    Software License, Version 1.0. (See accompanying file
    <code class="filename">LICENSE_1_0.txt</code> or copy at <a href="http://www.boost.org/LICENSE_1_0.txt" target="_top">http://www.boost.org/LICENSE_1_0.txt</a>)</p>
</div></td>
</tr></table>
<hr>
<div class="spirit-nav">
<a accesskey="p" href="misc.html"><img src="../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../function.html"><img src="../../../doc/src/images/up.png" alt="Up"></a><a accesskey="h" href="../index.html"><img src="../../../doc/src/images/home.png" alt="Home"></a><a accesskey="n" href="../heap.html"><img src="../../../doc/src/images/next.png" alt="Next"></a>
</div>
</body>
</html>
